<template>
    <div id="userRegisterPage">
        <h2 class="title">鱼皮云图库 - 用户注册</h2>
        <div class="desc">企业级智能协同云图库</div>
        <a-form :model="formState" name="basic" autocomplete="off" @finish="handleSubmit">
            <a-form-item name="userAccount" :rules="[{ required: true, message: '请输入账号' }]">
                <a-input v-model:value="formState.userAccount" placeholder="请输入账号" />
            </a-form-item>
            <a-form-item name="userPassword" :rules="[
                { required: true, message: '请输入密码' },
                { min: 8, message: '密码不能小于 8 位' },
            ]">
                <a-input-password v-model:value="formState.userPassword" placeholder="请输入密码" />
            </a-form-item>
            <a-form-item name="checkPassword" :rules="[
                { required: true, message: '请确认密码' },
                { min: 8, message: '确认密码不能小于 8 位' },
            ]">
                <a-input-password v-model:value="formState.checkPassword" placeholder="请确认密码" />
            </a-form-item>
            <div class="tips">
                已注册？
                <RouterLink to="/user/login">去登录</RouterLink>
            </div>
            <a-form-item>
                <a-button type="primary" html-type="submit" style="width: 100%">注册</a-button>
            </a-form-item>
        </a-form>
    </div>
</template>
<script lang="ts" setup>
import { reactive } from 'vue'
import { useRouter } from 'vue-router'
import { useLoginUserStore } from '@/stores/useLoginUserStore'
import { userLoginUsingPost, userRegisterUsingPost } from '@/api/yonghuxiangguanjiekou'
import { message } from 'ant-design-vue'

const formState = reactive<API.UserRegisterRequest>({
    userAccount: '',
    userPassword: '',
    checkPassword: '',
})

const router = useRouter()
const loginUserStore = useLoginUserStore()

/**
 * 提交表单
 * @param values
 */
const handleSubmit = async (values: any) => {
    // 判断两次输入的密码是否一致,如果不一致，则直接返回
    if(formState.userPassword !== formState.checkPassword){
        message.error("两次输入的密码不一致")
        return
    }
    const res = await userRegisterUsingPost(values)
    // 注册成功，跳转到登录页面
    try {
        if (res.data.code === 0 && res.data.data) {
        //await loginUserStore.fetchLoginUser()
        message.success('注册成功')
        router.push({
            path: '/user/login',
            replace: true,
        })
    } else {
        message.error('注册失败，' + res.data.message)
    }
    } catch (error) {
        message.error('注册失败，' + error)
    }
    
}


</script>
<style  scoped>
#userRegisterPage {
    max-width: 360px;
    margin: 0 auto;
}

.title {
    text-align: center;
    margin-bottom: 16px;
}

.desc {
    text-align: center;
    color: #bbb;
    margin-bottom: 16px;
}

.tips {
    margin-bottom: 16px;
    color: #bbb;
    font-size: 13px;
    text-align: right;
}
</style>